<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1">
	<title>Alias datatype | ElasticSearch 7.7 权威指南中文版</title>
	<meta name="keywords" content="ElasticSearch 权威指南中文版, elasticsearch 7, es7, 实时数据分析，实时数据检索" />
    <meta name="description" content="ElasticSearch 权威指南中文版, elasticsearch 7, es7, 实时数据分析，实时数据检索" />
    <!-- Give IE8 a fighting chance -->
    <!--[if lt IE 9]>
    <script src="https://oss.maxcdn.com/html5shiv/3.7.2/html5shiv.min.js"></script>
    <script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script>
    <![endif]-->
	<link rel="stylesheet" type="text/css" href="../static/styles.css" />
	<script>
	var _link = 'alias.html';
    </script>
</head>
<body>
<div class="main-container">
    <section id="content">
        <div class="content-wrapper">
            <section id="guide" lang="zh_cn">
                <div class="container">
                    <div class="row">
                        <div class="col-xs-12 col-sm-8 col-md-8 guide-section">
                            <div style="color:gray; word-break: break-all; font-size:12px;">原英文版地址: <a href="https://www.elastic.co/guide/en/elasticsearch/reference/7.7/alias.html" rel="nofollow" target="_blank">https://www.elastic.co/guide/en/elasticsearch/reference/7.7/alias.html</a>, 原文档版权归 www.elastic.co 所有<br/>本地英文版地址: <a href="../en/alias.html" rel="nofollow" target="_blank">../en/alias.html</a></div>
                        <!-- start body -->
                  <div class="page_header">
<strong>重要</strong>: 此版本不会发布额外的bug修复或文档更新。最新信息请参考 <a href="https://www.elastic.co/guide/en/elasticsearch/reference/current/index.html" rel="nofollow">当前版本文档</a>。
</div>
<div id="content">
<div class="breadcrumbs">
<span class="breadcrumb-link"><a href="index.html">Elasticsearch 权威指南 [7.7]</a></span>
»
<span class="breadcrumb-link"><a href="mapping.html">映射</a></span>
»
<span class="breadcrumb-link"><a href="mapping-types.html">字段数据类型</a></span>
»
<span class="breadcrumb-node">alias(别名)数据类型</span>
</div>
<div class="navheader">
<span class="prev">
<a href="mapping-types.html">« 字段数据类型</a>
</span>
<span class="next">
<a href="array.html">arrays(数组)数据类型 »</a>
</span>
</div>
<div class="section">
<div class="titlepage"><div><div>
<h2 class="title">
<a id="alias"></a>alias(别名)
</h2>
</div></div></div>

<p>
<code class="literal">alias</code>(别名) 映射为索引中的字段定义了一个备用名称。

alias(别名)可以用来代替<a class="xref" href="search.html" title="search API" rel="nofollow">search</a>请求中的目标字段，以及<a class="xref" href="search-field-caps.html" title="字段功能 API" rel="nofollow">字段功能</a>等选定的其他API。
</p>
<div class="pre_wrapper lang-console">
<pre class="programlisting prettyprint lang-console">PUT /trips
{
  "mappings": {
    "properties": {
      "distance": {
        "type": "long"
      },
      "route_length_miles": {
        "type": "alias",
        "path": "distance" <a id="CO288-1"></a><i class="conum" data-value="1"></i>
      },
      "transit_mode": {
        "type": "keyword"
      }
    }
  }
}

GET /_search
{
  "query": {
    "range" : {
      "route_length_miles" : {
        "gte" : 39
      }
    }
  }
}</pre>
</div>
<div class="console_widget" data-snippet="snippets/616.console"></div>
<div class="calloutlist">
<table border="0" summary="Callout list">
<tr>
<td align="left" valign="top" width="5%">
<p><a href="#CO288-1"><i class="conum" data-value="1"></i></a></p>
</td>
<td align="left" valign="top">
<p>
目标字段的路径。

注意，这里必须是完整路径，包括任何父对象(例如 <code class="literal">object1.object2.field</code>)。
</p>
</td>
</tr>
</table>
</div>
<p>
几乎所有搜索请求的组件都接受字段别名。

特别是，别名可用于查询、聚合和排序字段，以及请求<code class="literal">docvalue_fields</code>、<code class="literal">stored_fields</code>、建议和高亮显示。

访问字段值时，脚本也支持别名。

请参阅<a class="xref" href="alias.html#unsupported-apis" title="不支持的API" rel="nofollow">不支持的API</a>部分章节以了解异常情况。
</p>
<p>
在搜索请求的某些部分及请求字段功能时，可以提供字段通配符模式。

在这些情况下，除了具体字段之外，通配符模式还将匹配字段别名：
</p>
<div class="pre_wrapper lang-console">
<pre class="programlisting prettyprint lang-console">GET /trips/_field_caps?fields=route_*,transit_mode</pre>
</div>
<div class="console_widget" data-snippet="snippets/617.console"></div>
<div class="section">
<div class="titlepage"><div><div>
<h3 class="title">
<a id="alias-targets"></a>别名目标
</h3>
</div></div></div>
<p>别名的目标有一些限制：</p>
<div class="ulist itemizedlist">
<ul class="itemizedlist">
<li class="listitem">
目标必须是具体的字段，而不是对象或另一个字段别名。
</li>
<li class="listitem">
创建别名时，目标字段必须存在。
</li>
<li class="listitem">
如果定义了嵌套对象，字段别名必须具有与其目标相同的嵌套范围。
</li>
</ul>
</div>
<p>
此外，字段别名只能有一个目标。

这意味着不可能使用字段别名在单个子句中查询多个目标字段。
</p>
<p>
通过映射更新，可以更改别名以引用新目标。

一个已知的限制是，如果任何存储的 percolator 查询包含字段别名，它们仍将引用其原始目标。

更多信息可以在<a class="xref" href="percolator.html" title="percolator 类型" rel="nofollow">percolator文档</a>中找到。
</p>
</div>

<div class="section">
<div class="titlepage"><div><div>
<h3 class="title">
<a id="unsupported-apis"></a>不支持的API
</h3>
</div></div></div>
<p>
不支持写入字段别名：试图在编制索引或更新请求中使用别名将导致失败。

同样，别名不能用作<code class="literal">copy_to</code>的目标，也不能用于多字段。
</p>
<p>
因为文档的源中不存在别名，所以在执行源过滤时不能使用别名。

例如，以下请求将为<code class="literal">_source</code>返回一个空结果：
</p>
<div class="pre_wrapper lang-console">
<pre class="programlisting prettyprint lang-console">GET /_search
{
  "query" : {
    "match_all": {}
  },
  "_source": "route_length_miles"
}</pre>
</div>
<div class="console_widget" data-snippet="snippets/618.console"></div>
<p>
目前，只有搜索和字段功能API将接受和解析字段别名。

其他接受字段名的API(如<a class="xref" href="docs-termvectors.html" title="term vectors API" rel="nofollow">term vectors</a>)不能与字段别名一起使用。
</p>
<p>
最后，一些查询，比如<code class="literal">terms</code>、<code class="literal">geo_shape</code>和<code class="literal">more_like_this</code>，允许从索引文档中获取查询信息。

因为提取文档时不支持字段别名，所以指定查找路径的查询部分不能通过别名引用字段。
</p>
</div>

</div>
<div class="navfooter">
<span class="prev">
<a href="mapping-types.html">« 字段数据类型</a>
</span>
<span class="next">
<a href="array.html">数组 »</a>
</span>
</div>
</div>

                  <!-- end body -->
                        </div>
                        <div class="col-xs-12 col-sm-4 col-md-4" id="right_col">
                        
                        </div>
                    </div>
                </div>
            </section>
        </div>
    </section>
</div>
<script src="../static/cn.js"></script>
</body>
</html>